< Previous instruction: BZ | Instruction index | Next instruction: CLRF >

## CALL Subroutine Call

Syntax: [ label ] CALL k [,s]

Operands:  $0 \le k \le 1048575$ 

 $s \in [0,1]$ 

Operation:  $(PC) + 4 \rightarrow TOS$ ,

 $k \rightarrow PC < 20:1>$ 

if s = 1(W)  $\rightarrow$  WS,

(STATUS) → STATUSS,

(BSR) → BSRS

Status Affected: None

Encoding:

1st word (k<7:0>) 2nd word(k<19:8>)

| 1110 | l                   | k <sub>7</sub> kkk | kkkk <sub>o</sub> |
|------|---------------------|--------------------|-------------------|
| 1111 | k <sub>19</sub> kkk | kkkk               | kkkk <sub>8</sub> |

Description:

Subroutine call of entire 2 Mbyte memory range. First, return address (PC+ 4) is pushed onto the return stack. If 's' = 1, the W, STATUS and BSR registers are also pushed into their respective shadow registers, WS, STATUSS and BSRS. If 's' = 0, no update occurs (default). Then, the 20-bit value 'k' is loaded into PC<20:1>. CALL is a two-cycle instruction.

Words: 2 Cycles: 2

## Q Cycle Activity:

| Q1              | Q2                        | Q3                  | Q4                                        |
|-----------------|---------------------------|---------------------|-------------------------------------------|
| Decode          | Read literal<br>'k'<7:0>, | Push PC to<br>stack | Read literal<br>'k'<19:8>,<br>Write to PC |
| No<br>operation | No<br>operation           | No<br>operation     | No<br>operation                           |

Example: HERE CALL THERE, 1

Before Instruction

PC = address (HERE)

After Instruction

PC = address (THERE) TOS = address (HERE + 4)

WS = W BSRS = BSR STATUSS= STATUS

<sup>&</sup>lt; Previous instruction: <u>BZ</u> | Instruction <u>index</u> | Next instruction: <u>CLRF</u> >